草庐IT

$TCP 连接

全部标签

调用 Go RPC TCP 服务时 Ruby Socket 客户端挂起

我有一个用Go编写的工作RPCTCP服务,但是当使用Ruby连接到服务时它挂起,因为似乎没有数据通过打开的套接字连接发回。远程RPC函数:packageremoteimport"fmt"//ComposeisourRPCfunctionsreturntypetypeComposestring//DetailsisourexposedRPCfunctionfunc(c*Compose)Details(argstring,reply*string)error{fmt.Printf("Argreceived:%+v\n",arg)*c="somevalue"*reply="Blah!"ret

go - 使用 Go-Stomp 为 ActiveMQ 缓存连接

使用Go-Stomp,可以使用以下代码获取连接。ifconn,err=stomp.Dial("tcp",Broker.URI,stomp.ConnOpt.Login(Broker.User,Broker.Password));err!=nil{panic(fmt.Sprintf("CouldnotconnecttoActiveMQusingbrokerUri%v.Cannotcontinue.",Broker.URI))}是否可以缓存连接以重用以针对不同的请求发送消息?还是每次发送消息都需要获取连接?后来听起来效率低下。连接实例上的Send方法会在发生故障时关闭连接。因此,如果我们对其

sockets - UDP 代理,如何维护/重用/清除连接的客户端池?

我正在创建一个UDP-proxy在go,但在使用iperf进行一些负载测试时,我开始收到此错误:socket:toomanyopenfiles经过搜索和测试,我发现如果我使用map创建一个池打开连接是关键*net.UDPAddr.String()value是UDP-proxy的一个实例包含*net.UDPConn,如果客户端地址相同,我可以重用现有连接:varclientsmap[string]*UDPProxy.UDPProxy=make(map[string]*UDPProxy.UDPProxy)这blockcode看起来像://waitforconnectionsfor{n,cl

ruby - 这个示例 tcp 套接字编程事件顺序安全吗?

我计划提供两项服务。用Ruby编写的HTTPREST服务用Go编写的JSONRPC服务Ruby服务将打开一个到GoJSONRPC服务的TCP套接字连接。它将为收到的每个传入HTTP请求执行此操作。它会通过套接字向Go服务发送一些数据,然后该服务会通过套接字发回相应的数据。Go代码Go服务go看起来像这样(简化):srv:=new(service.App)//thiswouldexposeaProcessmethodrpc.Register(srv)listener,err:=net.Listen("tcp",":8080")iferr!=nil{//handleerror}for{co

Golang amqp 重新连接

我想测试与rabbitmq服务器的重启连接。就写了个小脚本来测试。http://play.golang.org/p/l3ZWzG0Qqb但它不起作用。在第10步中,我关闭了channel和连接。并再次打开它们。并重新创建chanamqp.Confirmation(:75)。并继续循环。但在那之后,chan确认没有任何返回。UPD:代码在这里。packagemainimport("fmt""github.com/streadway/amqp""log""os""time")constSERVER="amqp://user:pass@localhost:5672/"constEXCHANG

GORM pq 连接太多

我在我的项目中使用GORM,一切都很好,直到我收到一个错误:pq:sorry,toomanyclientsalready我只是使用默认配置。错误发生在我对我的应用程序做了很多测试请求之后。并且在我重新启动应用程序后错误消失了。所以,我认为在我完成查询后GORM连接不会被释放。我没有对GORM代码进行足够深入的检查,我只是在这里问一下,也许有人已经体验过了? 最佳答案 您收到的错误消息是PostgreSQL错误,而不是GORM。这是因为您多次打开数据库连接造成的。db,err:=gorm.Open("postgres","user=g

http - golang1.4 http服务器保持空闲连接

有没有办法在服务器端指定超时后保持空闲连接打开?我有一个使用golang1.4实现的http服务器,API将在10秒后响应。当我在客户端设置MaxIdleConnsPerHost(使用golang1.4)时,我仍然得到readtcpxx.xx.xx.xx:xx:useofclosednetworkconnection。我认为可能是服务器关闭空闲连接导致的。我找到了GOLANG,HTTPhaving“useofclosednetworkconnection”error和http.Server:timeoutforidleconnectionsonly?,但他们没有帮助。

ssl - 使用自签名证书的 TLS 连接失败

当使用我自己的“开发人员”证书访问内部服务在我的笔记本电脑上本地运行时,以下简化的测试用例代码有效如果我在远程机器上运行动态生成的证书(所有这些都由我组织中的一个单独的团队处理),它会失败并显示400和“没有发送必需的SSL证书”错误但如果我在远程机器上使用curl,并指定与我的Go代码中引用的证书相同的证书,它将起作用所以似乎证书不是问题,而是Go代码,但这本身似乎不是问题,因为它在本地使用我自己的证书packagemainimport("crypto/tls""crypto/x509""fmt""io/ioutil""net/http""os""time")funcmain(){t

go - 通过 SetDeadline() 为 TCP 监听器设置超时

我正在尝试实现非阻塞Accept(),目前为止最好的是以下代码片段(它是一个有效的Gov1.6.2程序):packagemainimport("net""log""time")funccreateClient(){tcpConn,err:=net.DialTCP("tcp4",nil,&net.TCPAddr{IP:net.IPv4(127,0,0,1),Port:12819,})iferr!=nil{log.Fatalln("Errorconnectingtotheserver!")}log.Println("Managedtodial!")tcpConn.Close()}funcm

go - 如何切换数据库连接并将其共享到 Golang 中的模型? (Revel + Gorm)

我想像https://github.com/thiagopradi/octopus这样设置数据库分片在Revel+Gorm(或Golang中的任何其他ORM)中。我将在securityfilter中获取数据库连接字符串(这是一个自定义过滤器,添加在revel的参数过滤器之后)。现在我需要在下一个名为dbfilter的自定义过滤器中切换数据库连接并且还需要在revel应用程序启动时实现数据库连接池。 最佳答案 首先是在初始化时准备好数据库连接(只调用一次):db1,err:=gorm.Open(dbdriver,dboption)//